@@ -49,10 +49,9 @@ urlpatterns += [ |
||
49 | 49 |
# 消息相关 |
50 | 50 |
urlpatterns += [ |
51 | 51 |
url(r'^msg/list$', message_views.message_list_api, name='message_list_api'), # 消息列表 |
52 |
- url(r'^msg/list/(?P<msg_type>\w+)$', message_views.message_type_list_api, name='message_type_list_api'), # 分类消息列表 |
|
53 |
- url(r'^msg/read$', message_views.message_read_api, name='message_read_api'), # 消息读取 |
|
54 |
- url(r'^msg/delete$', message_views.message_delete_api, name='message_delete_api'), # 消息删除 |
|
55 |
- url(r'^msg/delete/(?P<msg_type>\w+)$', message_views.message_delete_api, name='message_type_delete_api'), # 消息删除 |
|
52 |
+ url(r'^msg/(?P<msg_type>\w+)/list$', message_views.message_type_list_api, name='message_type_list_api'), # 分类消息列表 |
|
53 |
+ url(r'^msg/(?P<msg_type>\w+)/read$', message_views.message_type_read_api, name='message_type_read_api'), # 消息读取 |
|
54 |
+ url(r'^msg/(?P<msg_type>\w+)/delete$', message_views.message_type_delete_api, name='message_type_delete_api'), # 消息删除 |
|
56 | 55 |
] |
57 | 56 |
|
58 | 57 |
# 控制器相关 |
@@ -2,7 +2,7 @@ |
||
2 | 2 |
|
3 | 3 |
from django.contrib import admin |
4 | 4 |
|
5 |
-from message.models import UserMessageInfo |
|
5 |
+from message.models import UserMessageInfo, SystemMessageInfo, SystemMessageReadInfo, SystemMessageDeleteInfo |
|
6 | 6 |
|
7 | 7 |
|
8 | 8 |
class UserMessageInfoAdmin(admin.ModelAdmin): |
@@ -10,4 +10,22 @@ class UserMessageInfoAdmin(admin.ModelAdmin): |
||
10 | 10 |
list_filter = ('msg_type', 'read', 'status') |
11 | 11 |
|
12 | 12 |
|
13 |
+class SystemMessageInfoAdmin(admin.ModelAdmin): |
|
14 |
+ list_display = ('title', 'content', 'url', 'status', 'created_at', 'updated_at') |
|
15 |
+ list_filter = ('status', ) |
|
16 |
+ |
|
17 |
+ |
|
18 |
+class SystemMessageReadInfoAdmin(admin.ModelAdmin): |
|
19 |
+ list_display = ('user_id', 'msg_id', 'status', 'created_at', 'updated_at') |
|
20 |
+ list_filter = ('status', ) |
|
21 |
+ |
|
22 |
+ |
|
23 |
+class SystemMessageDeleteInfoAdmin(admin.ModelAdmin): |
|
24 |
+ list_display = ('user_id', 'msg_id', 'status', 'created_at', 'updated_at') |
|
25 |
+ list_filter = ('status', ) |
|
26 |
+ |
|
27 |
+ |
|
13 | 28 |
admin.site.register(UserMessageInfo, UserMessageInfoAdmin) |
29 |
+admin.site.register(SystemMessageInfo, SystemMessageInfoAdmin) |
|
30 |
+admin.site.register(SystemMessageReadInfo, SystemMessageReadInfoAdmin) |
|
31 |
+admin.site.register(SystemMessageDeleteInfo, SystemMessageDeleteInfoAdmin) |
@@ -0,0 +1,45 @@ |
||
1 |
+# -*- coding: utf-8 -*- |
|
2 |
+from __future__ import unicode_literals |
|
3 |
+ |
|
4 |
+from django.db import models, migrations |
|
5 |
+ |
|
6 |
+ |
|
7 |
+class Migration(migrations.Migration): |
|
8 |
+ |
|
9 |
+ dependencies = [ |
|
10 |
+ ('message', '0002_auto_20160120_1830'), |
|
11 |
+ ] |
|
12 |
+ |
|
13 |
+ operations = [ |
|
14 |
+ migrations.CreateModel( |
|
15 |
+ name='SystemMessageInfo', |
|
16 |
+ fields=[ |
|
17 |
+ ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), |
|
18 |
+ ('status', models.BooleanField(default=True, help_text='\u72b6\u6001', db_index=True, verbose_name='status')), |
|
19 |
+ ('created_at', models.DateTimeField(help_text='\u521b\u5efa\u65f6\u95f4', verbose_name='created_at', auto_now_add=True)), |
|
20 |
+ ('updated_at', models.DateTimeField(help_text='\u66f4\u65b0\u65f6\u95f4', verbose_name='updated_at', auto_now=True)), |
|
21 |
+ ('title', models.CharField(help_text='\u7cfb\u7edf\u6d88\u606f\u6807\u9898', max_length=255, verbose_name='title')), |
|
22 |
+ ('content', models.TextField(help_text='\u7cfb\u7edf\u6d88\u606f\u5185\u5bb9', null=True, verbose_name='content', blank=True)), |
|
23 |
+ ('url', models.CharField(help_text='\u7cfb\u7edf\u6d88\u606f\u94fe\u63a5', max_length=255, null=True, verbose_name='url', blank=True)), |
|
24 |
+ ], |
|
25 |
+ options={ |
|
26 |
+ 'verbose_name': 'systemmessageinfo', |
|
27 |
+ 'verbose_name_plural': 'systemmessageinfo', |
|
28 |
+ }, |
|
29 |
+ ), |
|
30 |
+ migrations.CreateModel( |
|
31 |
+ name='SystemMessageReadInfo', |
|
32 |
+ fields=[ |
|
33 |
+ ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), |
|
34 |
+ ('status', models.BooleanField(default=True, help_text='\u72b6\u6001', db_index=True, verbose_name='status')), |
|
35 |
+ ('created_at', models.DateTimeField(help_text='\u521b\u5efa\u65f6\u95f4', verbose_name='created_at', auto_now_add=True)), |
|
36 |
+ ('updated_at', models.DateTimeField(help_text='\u66f4\u65b0\u65f6\u95f4', verbose_name='updated_at', auto_now=True)), |
|
37 |
+ ('user_id', models.CharField(max_length=255, blank=True, help_text='\u7528\u6237\u552f\u4e00\u6807\u8bc6', null=True, verbose_name='user_id', db_index=True)), |
|
38 |
+ ('msg_id', models.CharField(max_length=255, blank=True, help_text='\u7cfb\u7edf\u6d88\u606f\u552f\u4e00\u6807\u8bc6', null=True, verbose_name='msg_id', db_index=True)), |
|
39 |
+ ], |
|
40 |
+ options={ |
|
41 |
+ 'verbose_name': 'systemmessagereadinfo', |
|
42 |
+ 'verbose_name_plural': 'systemmessagereadinfo', |
|
43 |
+ }, |
|
44 |
+ ), |
|
45 |
+ ] |
@@ -0,0 +1,29 @@ |
||
1 |
+# -*- coding: utf-8 -*- |
|
2 |
+from __future__ import unicode_literals |
|
3 |
+ |
|
4 |
+from django.db import models, migrations |
|
5 |
+ |
|
6 |
+ |
|
7 |
+class Migration(migrations.Migration): |
|
8 |
+ |
|
9 |
+ dependencies = [ |
|
10 |
+ ('message', '0003_systemmessageinfo_systemmessagereadinfo'), |
|
11 |
+ ] |
|
12 |
+ |
|
13 |
+ operations = [ |
|
14 |
+ migrations.CreateModel( |
|
15 |
+ name='SystemMessageDeleteInfo', |
|
16 |
+ fields=[ |
|
17 |
+ ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), |
|
18 |
+ ('status', models.BooleanField(default=True, help_text='\u72b6\u6001', db_index=True, verbose_name='status')), |
|
19 |
+ ('created_at', models.DateTimeField(help_text='\u521b\u5efa\u65f6\u95f4', verbose_name='created_at', auto_now_add=True)), |
|
20 |
+ ('updated_at', models.DateTimeField(help_text='\u66f4\u65b0\u65f6\u95f4', verbose_name='updated_at', auto_now=True)), |
|
21 |
+ ('user_id', models.CharField(max_length=255, blank=True, help_text='\u7528\u6237\u552f\u4e00\u6807\u8bc6', null=True, verbose_name='user_id', db_index=True)), |
|
22 |
+ ('msg_id', models.CharField(max_length=255, blank=True, help_text='\u7cfb\u7edf\u6d88\u606f\u552f\u4e00\u6807\u8bc6', null=True, verbose_name='msg_id', db_index=True)), |
|
23 |
+ ], |
|
24 |
+ options={ |
|
25 |
+ 'verbose_name': 'systemmessagedeleteinfo', |
|
26 |
+ 'verbose_name_plural': 'systemmessagedeleteinfo', |
|
27 |
+ }, |
|
28 |
+ ), |
|
29 |
+ ] |
@@ -57,8 +57,7 @@ class UserMessageInfo(CreateUpdateMixin): |
||
57 | 57 |
def __unicode__(self): |
58 | 58 |
return unicode(self.pk) |
59 | 59 |
|
60 |
- @property |
|
61 |
- def msg_info(self): |
|
60 |
+ def msg_info(self, user_id=None): |
|
62 | 61 |
try: |
63 | 62 |
group_photo = GroupPhotoInfo.objects.get(pk=self.photo_id) |
64 | 63 |
except GroupPhotoInfo.DoesNotExist: |
@@ -79,3 +78,49 @@ class UserMessageInfo(CreateUpdateMixin): |
||
79 | 78 |
'read': self.read, |
80 | 79 |
'created_at': self.created_at.replace(microsecond=0), |
81 | 80 |
} |
81 |
+ |
|
82 |
+ |
|
83 |
+class SystemMessageInfo(CreateUpdateMixin): |
|
84 |
+ title = models.CharField(_(u'title'), max_length=255, help_text=u'系统消息标题') |
|
85 |
+ content = models.TextField(_(u'content'), blank=True, null=True, help_text=u'系统消息内容') |
|
86 |
+ url = models.CharField(_(u'url'), max_length=255, blank=True, null=True, help_text=u'系统消息链接') |
|
87 |
+ |
|
88 |
+ class Meta: |
|
89 |
+ verbose_name = _('systemmessageinfo') |
|
90 |
+ verbose_name_plural = _('systemmessageinfo') |
|
91 |
+ |
|
92 |
+ def __unicode__(self): |
|
93 |
+ return unicode(self.pk) |
|
94 |
+ |
|
95 |
+ def msg_info(self, user_id=None): |
|
96 |
+ return { |
|
97 |
+ 'pk': self.pk, |
|
98 |
+ 'title': self.title, |
|
99 |
+ 'content': self.content, |
|
100 |
+ 'url': self.url, |
|
101 |
+ 'read': SystemMessageReadInfo.objects.filter(user_id=user_id, msg_id=self.pk).exists(), |
|
102 |
+ } |
|
103 |
+ |
|
104 |
+ |
|
105 |
+class SystemMessageReadInfo(CreateUpdateMixin): |
|
106 |
+ user_id = models.CharField(_(u'user_id'), max_length=255, blank=True, null=True, help_text=u'用户唯一标识', db_index=True) |
|
107 |
+ msg_id = models.CharField(_(u'msg_id'), max_length=255, blank=True, null=True, help_text=u'系统消息唯一标识', db_index=True) |
|
108 |
+ |
|
109 |
+ class Meta: |
|
110 |
+ verbose_name = _('systemmessagereadinfo') |
|
111 |
+ verbose_name_plural = _('systemmessagereadinfo') |
|
112 |
+ |
|
113 |
+ def __unicode__(self): |
|
114 |
+ return unicode(self.pk) |
|
115 |
+ |
|
116 |
+ |
|
117 |
+class SystemMessageDeleteInfo(CreateUpdateMixin): |
|
118 |
+ user_id = models.CharField(_(u'user_id'), max_length=255, blank=True, null=True, help_text=u'用户唯一标识', db_index=True) |
|
119 |
+ msg_id = models.CharField(_(u'msg_id'), max_length=255, blank=True, null=True, help_text=u'系统消息唯一标识', db_index=True) |
|
120 |
+ |
|
121 |
+ class Meta: |
|
122 |
+ verbose_name = _('systemmessagedeleteinfo') |
|
123 |
+ verbose_name_plural = _('systemmessagedeleteinfo') |
|
124 |
+ |
|
125 |
+ def __unicode__(self): |
|
126 |
+ return unicode(self.pk) |
@@ -3,13 +3,16 @@ |
||
3 | 3 |
from django.conf import settings |
4 | 4 |
from django.http import JsonResponse |
5 | 5 |
|
6 |
-from message.models import UserMessageInfo |
|
6 |
+from account.models import UserInfo |
|
7 |
+from message.models import UserMessageInfo, SystemMessageInfo, SystemMessageReadInfo, SystemMessageDeleteInfo |
|
7 | 8 |
|
8 | 9 |
from utils.page_utils import pagination |
9 | 10 |
|
10 |
-from utils.error.errno_utils import MessageStatusCode |
|
11 |
+from utils.error.errno_utils import UserStatusCode, MessageStatusCode |
|
11 | 12 |
from utils.error.response_utils import response |
12 | 13 |
|
14 |
+from utils.redis.rmessage import set_system_message_delete_info, get_system_message_delete_info |
|
15 |
+ |
|
13 | 16 |
|
14 | 17 |
def message_list_api(request): |
15 | 18 |
""" |
@@ -23,14 +26,24 @@ def message_list_api(request): |
||
23 | 26 |
|
24 | 27 |
final_messages = [] |
25 | 28 |
for message in messages: |
26 |
- type_messages = UserMessageInfo.objects.filter( |
|
27 |
- to_uid=user_id, |
|
28 |
- msg_type=message['msg_type'], |
|
29 |
- status=True, |
|
30 |
- ).order_by( |
|
29 |
+ msg_type = message['msg_type'] |
|
30 |
+ if msg_type == UserMessageInfo.SYSTEM: |
|
31 |
+ deleted_message_ids = get_system_message_delete_info(user_id) |
|
32 |
+ type_messages = SystemMessageInfo.objects.filter( |
|
33 |
+ status=True, |
|
34 |
+ ).exclude( |
|
35 |
+ pk__in=deleted_message_ids, |
|
36 |
+ ) |
|
37 |
+ else: |
|
38 |
+ type_messages = UserMessageInfo.objects.filter( |
|
39 |
+ to_uid=user_id, |
|
40 |
+ msg_type=msg_type, |
|
41 |
+ status=True, |
|
42 |
+ ) |
|
43 |
+ type_messages = type_messages.order_by( |
|
31 | 44 |
'-pk' |
32 | 45 |
)[:settings.MESSAGE_NUM_PER_PAGE] |
33 |
- type_messages = [msg.msg_info for msg in type_messages] |
|
46 |
+ type_messages = [msg.msg_info(user_id) for msg in type_messages] |
|
34 | 47 |
message['msg_list'] = type_messages |
35 | 48 |
final_messages.append(message) |
36 | 49 |
|
@@ -54,15 +67,24 @@ def message_type_list_api(request, msg_type): |
||
54 | 67 |
page = int(request.POST.get('page', 0) or request.GET.get('page', 0) or 1) |
55 | 68 |
num = int(request.POST.get('num', 0) or request.GET.get('num', 0) or settings.MESSAGE_NUM_PER_PAGE) |
56 | 69 |
|
57 |
- type_messages = UserMessageInfo.objects.filter( |
|
58 |
- to_uid=user_id, |
|
59 |
- msg_type=msg_type, |
|
60 |
- status=True, |
|
61 |
- ).order_by( |
|
70 |
+ if msg_type == UserMessageInfo.SYSTEM: |
|
71 |
+ deleted_message_ids = get_system_message_delete_info(user_id) |
|
72 |
+ type_messages = SystemMessageInfo.objects.filter( |
|
73 |
+ status=True, |
|
74 |
+ ).exclude( |
|
75 |
+ pk__in=deleted_message_ids, |
|
76 |
+ ) |
|
77 |
+ else: |
|
78 |
+ type_messages = UserMessageInfo.objects.filter( |
|
79 |
+ to_uid=user_id, |
|
80 |
+ msg_type=msg_type, |
|
81 |
+ status=True, |
|
82 |
+ ) |
|
83 |
+ type_messages = type_messages.order_by( |
|
62 | 84 |
'-pk' |
63 | 85 |
) |
64 | 86 |
type_messages, left = pagination(type_messages, page, num) |
65 |
- type_messages = [msg.msg_info for msg in type_messages] |
|
87 |
+ type_messages = [msg.msg_info(user_id) for msg in type_messages] |
|
66 | 88 |
|
67 | 89 |
return JsonResponse({ |
68 | 90 |
'status': 200, |
@@ -74,16 +96,35 @@ def message_type_list_api(request, msg_type): |
||
74 | 96 |
}) |
75 | 97 |
|
76 | 98 |
|
77 |
-def message_read_api(request): |
|
99 |
+def message_type_read_api(request, msg_type=None): |
|
78 | 100 |
""" |
79 | 101 |
消息读取 |
80 | 102 |
:param request: |
81 | 103 |
:return: |
82 | 104 |
""" |
83 |
- pk = int(request.POST.get('pk', 0) or request.GET.get('pk', 0) or -1) |
|
84 | 105 |
user_id = request.POST.get('user_id', '') or request.GET.get('user_id', '') |
85 |
- |
|
86 |
- UserMessageInfo.objects.filter(pk=pk, to_uid=user_id).update(read=True) |
|
106 |
+ pk = int(request.POST.get('pk', 0) or request.GET.get('pk', 0) or -1) |
|
107 |
+ _all = request.POST.get('all', '') or request.GET.get('all', '') |
|
108 |
+ |
|
109 |
+ # 用户校验 |
|
110 |
+ try: |
|
111 |
+ user = UserInfo.objects.get(user_id=user_id) |
|
112 |
+ except UserInfo.DoesNotExist: |
|
113 |
+ return response(UserStatusCode.USER_NOT_FOUND) |
|
114 |
+ |
|
115 |
+ if msg_type == UserMessageInfo.SYSTEM: |
|
116 |
+ if pk > 0: # 系统消息单个读取 |
|
117 |
+ if not SystemMessageInfo.objects.filter(pk=pk).exists(): |
|
118 |
+ return response(MessageStatusCode.MESSAGE_NOT_FOUND) |
|
119 |
+ SystemMessageReadInfo.objects.get_or_create(user_id=user_id, msg_id=pk) |
|
120 |
+ if _all: # 系统消息全部读取 |
|
121 |
+ for msg in SystemMessageInfo.objects.filter(status=True): |
|
122 |
+ SystemMessageReadInfo.objects.get_or_create(user_id=user_id, msg_id=msg.pk) |
|
123 |
+ else: |
|
124 |
+ if pk > 0: # 用户(点赞/评论)消息单个读取 |
|
125 |
+ UserMessageInfo.objects.filter(pk=pk, to_uid=user_id).update(read=True) |
|
126 |
+ if _all: # 用户消息(点赞/评论)全部读取 |
|
127 |
+ UserMessageInfo.objects.filter(to_uid=user_id, msg_type=msg_type).update(read=True) |
|
87 | 128 |
|
88 | 129 |
return JsonResponse({ |
89 | 130 |
'status': 200, |
@@ -91,7 +132,7 @@ def message_read_api(request): |
||
91 | 132 |
}) |
92 | 133 |
|
93 | 134 |
|
94 |
-def message_delete_api(request, msg_type=None): |
|
135 |
+def message_type_delete_api(request, msg_type=None): |
|
95 | 136 |
""" |
96 | 137 |
消息删除 |
97 | 138 |
:param request: |
@@ -99,12 +140,29 @@ def message_delete_api(request, msg_type=None): |
||
99 | 140 |
:return: |
100 | 141 |
""" |
101 | 142 |
user_id = request.POST.get('user_id', '') or request.GET.get('user_id', '') |
102 |
- |
|
103 |
- if msg_type: |
|
104 |
- UserMessageInfo.objects.filter(to_uid=user_id, msg_type=msg_type).update(status=False) |
|
143 |
+ pk = int(request.POST.get('pk', 0) or request.GET.get('pk', 0) or -1) |
|
144 |
+ _all = request.POST.get('all', '') or request.GET.get('all', '') |
|
145 |
+ |
|
146 |
+ # 用户校验 |
|
147 |
+ try: |
|
148 |
+ user = UserInfo.objects.get(user_id=user_id) |
|
149 |
+ except UserInfo.DoesNotExist: |
|
150 |
+ return response(UserStatusCode.USER_NOT_FOUND) |
|
151 |
+ |
|
152 |
+ if msg_type == UserMessageInfo.SYSTEM: |
|
153 |
+ if pk > 0: # 系统消息单个删除 |
|
154 |
+ if not SystemMessageInfo.objects.filter(pk=pk).exists(): |
|
155 |
+ return response(MessageStatusCode.MESSAGE_NOT_FOUND) |
|
156 |
+ SystemMessageDeleteInfo.objects.get_or_create(user_id=user_id, msg_id=pk) |
|
157 |
+ if _all: # 系统消息全部删除 |
|
158 |
+ for msg in SystemMessageInfo.objects.filter(status=True): |
|
159 |
+ SystemMessageDeleteInfo.objects.get_or_create(user_id=user_id, msg_id=msg.pk) |
|
160 |
+ set_system_message_delete_info(user_id) |
|
105 | 161 |
else: |
106 |
- pk = int(request.POST.get('pk', 0) or request.GET.get('pk', 0) or -1) |
|
107 |
- UserMessageInfo.objects.filter(pk=pk, to_uid=user_id).update(status=False) |
|
162 |
+ if pk > 0: # 用户(点赞/评论)消息单个删除 |
|
163 |
+ UserMessageInfo.objects.filter(pk=pk, to_uid=user_id).update(status=False) |
|
164 |
+ if _all: # 用户消息(点赞/评论)全部删除 |
|
165 |
+ UserMessageInfo.objects.filter(to_uid=user_id, msg_type=msg_type).update(status=False) |
|
108 | 166 |
|
109 | 167 |
return JsonResponse({ |
110 | 168 |
'status': 200, |
@@ -1,7 +1,7 @@ |
||
1 | 1 |
# -*- coding: utf-8 -*- |
2 | 2 |
|
3 | 3 |
# 用户相关 |
4 |
-PROFILE_INFO = 'profile:info:%s' # STRING,用户信息,uid |
|
4 |
+PROFILE_INFO = 'profile:info:%s' # STRING,用户信息,user_id |
|
5 | 5 |
|
6 | 6 |
# 群组相关 |
7 | 7 |
GROUP_INFO = 'group:info:%s' # STRING,群组信息,group_id |
@@ -16,3 +16,6 @@ GROUP_USERS_QUIT_SET = 'group:users:quit:set:%s' # SET,群组用户退出集 |
||
16 | 16 |
|
17 | 17 |
# 群组照片相关 |
18 | 18 |
GROUP_LAST_PHOTO_PK = 'group:last:photo:pk:%s' # STRING,群组最后一张照片PK,group_id |
19 |
+ |
|
20 |
+# 系统消息相关 |
|
21 |
+SYSTEM_MESSAGE_DELETED_INFO = 'system:message:deleted:info:%s' # STRING,系统消息删除信息,user_id |
@@ -0,0 +1,28 @@ |
||
1 |
+# -*- coding: utf-8 -*- |
|
2 |
+ |
|
3 |
+from django.conf import settings |
|
4 |
+ |
|
5 |
+from message.models import SystemMessageDeleteInfo |
|
6 |
+ |
|
7 |
+from utils.redis.rkeys import SYSTEM_MESSAGE_DELETED_INFO |
|
8 |
+ |
|
9 |
+import json |
|
10 |
+ |
|
11 |
+ |
|
12 |
+r = settings.REDIS_CACHE |
|
13 |
+ |
|
14 |
+ |
|
15 |
+# 系统消息相关 |
|
16 |
+ |
|
17 |
+ |
|
18 |
+def set_system_message_delete_info(user_id): |
|
19 |
+ """ 设置系统消息删除信息 """ |
|
20 |
+ deleted_messages = SystemMessageDeleteInfo.objects.filter(user_id=user_id, status=True) |
|
21 |
+ deleted_message_ids = [msg.msg_id for msg in deleted_messages] |
|
22 |
+ r.set(SYSTEM_MESSAGE_DELETED_INFO % user_id, json.dumps(deleted_message_ids)) |
|
23 |
+ return deleted_message_ids |
|
24 |
+ |
|
25 |
+ |
|
26 |
+def get_system_message_delete_info(user_id): |
|
27 |
+ """ 获取系统消息删除信息 """ |
|
28 |
+ return json.loads(r.get(SYSTEM_MESSAGE_DELETED_INFO % user_id) or '[]') or set_system_message_delete_info(user_id) |